Game control using three-dimensional motions of controller

ABSTRACT

A method for use in an interactive system includes receiving position information for a controller that is being manipulated by a user, analyzing the received position information to determine whether a predetermined movement of the controller has been performed, and changing the user&#39;s viewpoint of a scene displayed on a display in response to the predetermined movement of the controller being performed. Another embodiment provides a method for use in an interactive system that includes moving at least a portion of a character in a scene displayed on a display in response to the predetermined movement of the controller being performed.

BACKGROUND OF THE INVENTION

1. Field of the Invention

The present invention relates generally to computer entertainment systems, and more specifically to a user's manipulation of a controller for such computer entertainment systems.

2. Discussion of the Related Art

Computer entertainment systems typically include a hand-held controller, game controller, or other controller. A user or player uses the controller to send commands or other instructions to the entertainment system to control a video game or other simulation being played. For example, the controller may be provided with a manipulator which is operated by the user, such as a joy stick. The manipulated variable of the joy stick is converted from an analog value into a digital value, which is sent to the game machine main frame. The controller may also be provided with buttons that can be operated by the user.

It is with respect to these and other background information factors that the present invention has evolved.

SUMMARY OF THE INVENTION

One embodiment provides a method for use in an interactive system, comprising: receiving position information for a controller that is being manipulated by a user; analyzing the received position information to determine whether a predetermined movement of the controller has been performed; and changing the user's viewpoint of a scene displayed on a display in response to the predetermined movement of the controller being performed.

Another embodiment provides a method for use in an interactive system, comprising: receiving position information for a controller that is being manipulated by a user; analyzing the received position information to determine whether a predetermined movement of the controller has been performed; and moving at least a portion of a character in a scene displayed on a display in response to the predetermined movement of the controller being performed.

A better understanding of the features and advantages of various embodiments of the present invention will be obtained by reference to the following detailed description and accompanying drawings which set forth an illustrative embodiment in which principles of embodiments of the invention are utilized.

BRIEF DESCRIPTION OF THE DRAWINGS

The above and other aspects, features and advantages of embodiments of the present invention will be more apparent from the following more particular description thereof, presented in conjunction with the following drawings wherein:

FIG. 1A is a pictorial diagram illustrating a system that operates in accordance with an embodiment of the present invention;

FIG. 1B is a perspective view of a controller made in accordance with an embodiment of the present invention;

FIG. 1C is a perspective view of a controller made in accordance with an embodiment of the present invention;

FIG. 1D is a perspective view of a controller made in accordance with an embodiment of the present invention;

FIG. 1E is a perspective view of a controller made in accordance with some embodiments of the present invention;

FIG. 2A is a pictorial diagram illustrating a manner for determining position information for a controller in accordance with an embodiment of the present invention;

FIG. 2B is a planar view of an image plane illustrating a manner for determining position information for a controller in accordance with an embodiment of the present invention;

FIG. 3A is a flow diagram illustrating a method for use in obtaining information in accordance with an embodiment of the present invention;

FIG. 3B is a flow diagram illustrating a method for use in providing input to a system in accordance with an embodiment of the present invention;

FIG. 4 is a block diagram illustrating a system that may be used to run, implement and/or execute the methods and techniques shown and described herein in accordance with embodiments of the present invention;

FIG. 5 is a block diagram illustrating a processor that may be used to run, implement and/or execute the methods and techniques shown and described herein in accordance with embodiments of the present invention; and

FIGS. 6A, 6B, and 6C are pictorial diagrams illustrating a system that operates in accordance with another embodiment of the present invention;

FIG. 7 is a flow diagram illustrating a method for use in controlling a system in accordance with an embodiment of the present invention;

FIG. 8 is a pictorial diagram illustrating a system that operates in accordance with another embodiment of the present invention;

FIG. 9 is a block diagram illustrating a system that operates in accordance with another embodiment of the present invention;

FIG. 10 is a pictorial diagram illustrating a system that operates in accordance with another embodiment of the present invention;

FIGS. 11A and 11B are perspective diagrams illustrating controllers that may optionally be used in the described systems in accordance with embodiments of the present invention;

FIG. 12 is a flow diagram illustrating a method for use in an interactive system in accordance with another embodiment of the present invention;

FIGS. 13A and 13B are screen shots illustrating an application of the method shown in FIG. 12 in accordance with an embodiment of the present invention;

FIG. 14 is a flow diagram illustrating a method for use in an interactive system in accordance with another embodiment of the present invention; and

FIG. 15 is a screen shot illustrating a method in accordance with an embodiment of the present invention.

DETAILED DESCRIPTION

The user or player of a video game typically holds the game controller with one or both hands in order to operate the buttons, joy stick, etc., located on the controller. Often times while playing the game the user will also move the entire controller itself around in the air as he or she simultaneously operates the buttons, joy stick, etc. Some users tend to get excited while playing the game and attempt to control actions or aspects of the game by moving the entire controller itself around in the air.

Various embodiments of the methods, apparatus, schemes and systems described herein provide for the detection, capture and tracking of the movements, motions and/or manipulations of the entire controller body itself by the user. The detected movements, motions and/or manipulations of the entire controller body by the user may be used as additional commands to control various aspects of the game or other simulation being played.

Detecting and tracking a user's manipulations of a game controller body may be implemented in different ways. For example, in some embodiments a camera peripheral can be used with the computer entertainment system to detect motions of the hand-held controller body and transfer them into actions in a game. The camera can be used to detect many different types of motions of the controller, such as for example up and down movements, twisting movements, side to side movements, jerking movements, wand-like motions, plunging motions, etc. Such motions may correspond to various commands such that the motions are transferred into actions in a game.

Detecting and tracking the user's manipulations of a game controller body can be used to implement many different types of games, simulations, etc., that allow the user to, for example, engage in a sword or lightsaber fight, use a wand to trace the shape of items, engage in many different types of sporting events, engage in on-screen fights or other encounters, etc.

Referring to FIG. 1A, there is illustrated a system 100 that operates in accordance with an embodiment of the present invention. As illustrated, a computer entertainment system or console 102 uses a television or other video display 104 to display the images of the video game or other simulation thereon. The game or other simulation may be stored on a DVD, CD, flash memory, USB memory, or other memory media 106 that is inserted into the console 102. A user or player 108 manipulates a game controller 110 to control the video game or other simulation.

A camera or other video image capturing device 112 is positioned so that the controller 110 is within the camera's field of view 114. As illustrated, the camera 110 may be placed on the video display 104, but it should be well understood that the camera may be located elsewhere. By way of example, the camera 112 may comprise a camera peripheral device such as the commercially available EyeToy™ product. But it should be well understood that any type or brand of camera may be used, such as for example a web-cam camera, add-on USB camera, infrared (IR) capability camera, fast frame capture rate camera, etc.

During operation, the user 108 physically moves the controller 110 itself. That is, the user 108 physically moves the entire controller 110 around in the air. For example, the controller 110 may be moved in any direction by the user 108, such as up, down, to one side, to the other side, twisted, rolled, shaken, jerked, plunged, etc. These movements of the controller 110 itself may be detected and captured by the camera 112 by way of tracking through image analysis in a manner described below.

In general, the detected and captured movements of the controller 110 are used to generate position and orientation data for the controller 110. Because this data is gathered on an image frame-by-frame basis, the data can be used to calculate many physical aspects of the movement of the controller 110, such as for example its acceleration and velocity along any axis, its tilt, pitch, yaw, roll, as well as any telemetry points of the controller 110.

The ability to detect and track the movements of the controller 110 makes it possible to determine whether any predefined movements of the controller 110 are performed. That is, certain movement patterns or gestures of the controller 110 may be predefined and used as input commands for the game or other simulation. For example, a plunging downward gesture of the controller 110 may be defined as one command, a twisting gesture of the controller 110 may be defined as another command, a shaking gesture of the controller 110 may be defined as another command, and so on. In this way the manner in which the user 108 physically moves the controller 110 itself is used as another input for controlling the game, which provides a more stimulating and entertaining experience for the user. Examples of how movements of the controller 110 can be mapped to input commands for the game will be discussed below.

Referring to FIG. 1B, there is illustrated a more detailed view of the controller 110 that is made in accordance with an embodiment of the present invention. The controller 110 includes a body 111. The body 111 is the part of the game controller 110 that one would hold by hand (or wear if it were a wearable game controller). An input device manipulable by a user is something such as, for example, a button or multi-axis control stick on the controller. One or more buttons may be disposed on the body 111. The body may include a housing holdable by hand. The housing may include a handgrip graspable by hand. Thus, during operation when the user 108 physically moves the controller 110 itself, the user 108 physically moves the body 111 of the controller 110. The user moves the body 111 around in the air, or in free-space.

The body 111 may have a forward section to be oriented towards a screen when a progress of a game controlled in accordance with the game controller is displayed upon the screen. At least one input device may be assembled with the body 111 with the input device manipulable by a user to register an input from the user.

One or more light-emitting diodes (LEDs) may be disposed on the body that are arranged in a geometric shape. Or, another type of photonically detectable (“PD”) element may be assembled with the body 111. A position of the photonically detectable element may be within an image being recorded by an image capture device when the forward section is oriented at least generally towards the screen. The positions of the PD element at different points in time may be quantifiable at quantify movement of the body 111 in space.

In this embodiment, the controller 110 includes four light-emitting diodes (LEDs) 122, 124, 126, 128. As illustrated, the four LEDs 122, 124, 126, 128 may be arranged in a substantially square or rectangular pattern and located on the bridge of the controller 110 between the R1 and L1 buttons. Thus, in this embodiment the geometric shape comprises a substantially square or rectangular pattern. The square or rectangular pattern formed by the four LEDs 122, 124, 126, 128 will be referred to herein as the “bounding box” formed by the LEDs.

It should be well understood that the geometric shape may comprise many different shapes. For example, the geometric shape may comprise any linear or two-dimensional pattern. Although a linear array of LEDs is preferred, the LEDs may alternatively, be arranged in a rectangular pattern or an arcuate pattern to facilitate determination of an image plane of the LED array when analyzing an image of the LED pattern obtained by an image capture camera.

While the illustrated embodiment of the controller utilizes four LEDs, it should be well understood that other embodiments may utilize more than four LEDs or less than four LEDs. For example, three LEDs will work, and two LEDs will also work to provide tracking information. Even one LED can provide position information. Furthermore, the LEDs may be located on a different part of the controller 110.

The LEDs may be positioned or disposed on the controller 110 in a variety of ways, including in a cluster, a line, a triangle, and/or other such configurations. One LED may be used or multiple LEDs can be used. In the case of multiple LEDs, in one configuration, the plane that is formed that intersects the LEDs may be tilted with respect to the orientation of the controller. The actual orientation of the controller may be determined by performing a transformation of data received in the image plane to determine the controller orientation. Additionally or alternatively, the LEDs can be removable, attachable and/or detachable. For example, the LEDs can be included on a plate or separate casing that is detachable from the body 111.

Referring to FIG. 1C, there is illustrated a view of the controller 110 that is made in accordance with an embodiment of the present invention. The controller 110 includes the body 111 and a cluster or array of LEDs 122, 124, 126 and 128. As illustrated, the four LEDs 122, 124, 126, 128 may be arranged in a substantially linear pattern and located on the bridge of the controller 110 between the R1 and L1 buttons. Thus, in this embodiment the geometric shape comprises a substantially linear pattern. Further in some embodiments, one or more of the LEDs can be implemented through infrared LEDs. For example, infrared LEDs can be paired with the visible LEDs. The visible LEDs can, for example, show a player ID. In some implementations, the LEDs may be surface mounted, with the infrared LEDs peeking through small windows that allow both visible LED and infrared LED transmission.

Referring to FIG. 1D, there is illustrated a view of the controller 110 that is made in accordance with an embodiment of the present invention. The controller 110 includes the body 111 and a communications interface and/or port 132. The interface, in some embodiments, allows the controller to couple directly with a tracking device and/or the console 102. The tracking devices at least in part can allow for the detection of movement of the controller 110, by optical, audio and/or inertia. The interface 132 can be substantially any relevant communication interface, such as a universal serial bus (USB) interface, universal asynchronous receiver transmitter (UART), and/or other such relevant interface. The interface 132 can be positioned on the controller 110 in substantially any position. As illustrated, the interface 132 may be located on the bridge of the controller 110 between the R1 and L1 buttons.

Referring to FIG. 1E, there is depicted a perspective view of the controller 110 that is made in accordance with some embodiments of the present invention. The controller includes the body 111, the R1 and L1 buttons, the one or more LEDs 122, 124, 126 and 128, the interface 132 (e.g., a USB interface), and other relevant buttons, indicators and the like. The LEDs 122, 124, 126 and 128 are shown in the linear pattern, however, other patterns can be employed as described above and further below. Additionally in some implementations, the LEDs and/or interface 132 can be removable, attachable and/or detachable.

The four LEDs 122, 124, 126, 128 produce four points or dots that are perceived by camera 112 (FIG. 1A). Because the camera 112 is looking at the player 108 with the controller 110 in his hands, the camera 112 is able to track the movement of the controller 110 by tracking the movement of the dots produced by the four LEDs 122, 124, 126, 128 and the bounding box that they form.

Namely, as the user 108 twists and rotates the controller body 110 the projection of the four dots are cast on the image plane of the camera 112's outputs. Image analysis is used to track the user's manipulations of the controller and to determine controller position and orientation. Thus, the four LEDs 122, 124, 126, 128 produce information regarding the body's movement. The positions of one or two controllers can be determined, or the relative movements of two controllers can be tracked.

FIG. 2A illustrates an example of how the bounding box is used to track the movements of the controller. Specifically, the controller, and thus the four LEDs 122, 124, 126, 128, are located within the field of view 114 of the camera 112. The four LEDs 122, 124, 126, 128 form a bounding box 202 when the controller is in a first position. When the controller is moved to a second position the four LEDs 122, 124, 126, 128 form a second bounding box 204. In addition, when the controller is moved from the first to the second position, the intermediate positions of the bounding boxes are also captured, depending on the speed of the movement and the frame rate of the camera 112.

The bounding boxes 202 and 204 formed by the four LEDs 122, 124, 126, 128 are captured in the image plane of the camera 112. FIG. 2B illustrates an example of the image plane 220 of the camera 112 showing the bounding boxes 202 and 204. A physics analysis is performed to derive and determine the movements of the bounding box and how the rectangle of the bounding box deforms into different shapes based on the tilt, yaw, etc. of the controller. By projecting the bounding boxes on the image plane, the position, orientation, acceleration, velocity, etc., of the controller can be determined, which can in turn be used to track the user's manipulations of the game controller.

Referring to FIG. 3A, there is illustrated a method 300 for use in obtaining information from a controller in accordance with an embodiment of the present invention. The method 300 may be executed and performed by many different types of systems and devices, such as for example entertainment systems and consoles, computers, consumer electronics device, etc. An example of a system that may be used to perform the method 300 will be described below.

The method 300 begins in step 302 in which a projection of a geometric shape established on the controller is received on an image plane of a camera. This step may be performed as has already been described above.

In step 304 the movements and deformities in the projection of the geometric shape are analyzed. Namely, the four dots of the bounding box are tracked and analyzed. Field and frame analysis is performed on the image plane of the camera output to analyze the manipulation of the four reference points to determine position orientation, tilt, yaw, roll, etc. of the controller. In addition, acceleration of the controller can be tracked in any direction. Analysis of the frames of the image can give the acceleration along any axis. Telemetry points of the controller can also be computed. It can also be determined whether or not the controller is in a resting position or resting state, such as for example when the controller is in a neutral or steady state near the user's waist.

As the controller rolls the image translates in the plane. Changes in the width of the rectangle of the bounding box indicate the controller is rolling. As the yaw of the controller is adjusted, the width of the rectangle changes. Yaw maps to the width of the rectangle. Tilt of the controller influences the height of the rectangle.

For example, the bounding box 202 (FIG. 2B) indicates that the controller was initially positioned looking fairly straight ahead at the camera. The bounding box 204 indicates that the controller was then moved downward, rolled and turned to the user's left.

It is difficult to know which side of the “ground plane” the controller is positioned on because the image plane only sees a deformed rectangle. For example, this issue can occur if someone walks in front of and occludes the camera during a time when the user manipulates the controller and moves the controller to an equal distance on the other side of an axis horizon line. This may cause the bounding box to look the same in the image plane. This can also happen if the controller travels outside of the viewing region of the image capture device.

As such, a determination may need to be made as to whether the deformation is caused by positive or negative tilt or roll (positive and negative being related to up/down and left/right movements away from the steady state origin position). This can be solved by reading other telemetry from the controller or by strobing or modulating the LEDs to enable the video analyzer system to discriminate individual corners of the bounding box rectangle for tracking purposes. The LEDs may be strobed or modulated as an aid for discerning the different corners of the bounding box. Or, each LED may have its own frequency as an aid for discerning the different corners of the bounding box. By identifying each specific corner of a bounding region, i.e. each LED, it can be determined which side of a horizontal line the controller is on at any point in time. In this way problems associated with the controller passing through the camera plane can be handled.

Tracking the movements and rotations of the bounding box on the screen is based on a frame-by-frame analysis. The camera's output creates the frames of image data. The projection of the bounding box is captured in software. The movements of the controller across the frames is based on the translation of the box.

The use of a high frame rate provides the ability to accurately track acceleration and changes in acceleration of the movement of the controller. That is, by projecting the image on the plane at high rates, the delta movements of the controller can be tracked. This provides the ability to plot the acceleration, the points where the acceleration peaks out, the points where gravity zeros out, and the points of inflection. The points of inflection are the transition points where the controller stops and changes direction. All of this analysis is performed by analyzing the frames of the image and determining the position and deformation of the bounding box. By way of example, frame rates of 120 frames per second or higher may be used, but it should well understood that any frame rate may be used.

As will be discussed below, the history of previous frames may be mapped. This allows the previous telemetry of the controller to be looked at for determining certain parameters such as, for example, in tracking acceleration, velocity, and stopping points.

In step 306 (FIG. 3A) position information for the controller is determined based on the analysis of the movements and deformities in the projection of the geometric shape. By way of example, an image analyzer may be used to perform one or both of steps 304 and 306. Namely, an image analyzer may be used to perform the analysis of the movements and deformations of the bounding boxes in the image plane of the camera. The output of the video camera may be coupled to the input of an image analyzer. An example of a system which may incorporate an image analyzer for implementing one or more of the methods, schemes and functions described herein will be discussed below.

The image analyzer monitors the bounding box formed by the reference LEDs as captured in the image plane of the camera. The image analyzer analyzes the position, rotation, horizontal and vertical deformation of the bounding box to determine the physical user manipulation of the controller, its position, roll, tilt and yaw coordinates. At the end of the image analysis the data may be output in the form of an output ID or the like. Such output IDs from the image analysis may include data such as the x, y, z coordinates, acceleration and velocity along any axis, that the controller is in a resting position or state, etc. Thus, at the end of image analysis the image analyzer can indicate where the controller is and whether a command is issued. And the image analyzer may be pinged at any instant of time and it may provide position, orientation, last command, etc.

By way of example, the image analyzer may provide, but shall not be limited to providing the following outputs:

CONTROLLER POSITION (X, Y, Z coordinates);

CONTROLLER ORIENTATION alpha, beta, gamma (radians);

CONTROLLER X-AXIS VELOCITY;

CONTROLLER Y-AXIS VELOCITY;

CONTROLLER Z-AXIS VELOCITY;

CONTROLLER X-AXIS ACCELERATION;

CONTROLLER Y-AXIS ACCELERATION;

CONTROLLER Z-AXIS ACCELERATION;

RESTING POSITION OF STEADY STATE Y/N (at waist as described, but may be defined as any position);

TIME SINCE LAST STEADY STATE;

LAST GESTURE RECOGNIZED;

TIME LAST GESTURE RECOGNIZED; and

INTERRUPT ZERO-ACCELERATION POINT REACHED.

Each of these outputs may be generated by analyzing the movements and deformations of the bounding box as described above. These outputs may be further processed in order to track the movement of the controller. Such tracking will allow certain movements of the controller to be recognized, which can then be used to trigger certain commands as described below. It should be well understood that many other outputs may be used in addition to or in replacement of the above-listed outputs.

Additional inputs to the image analyzer may optionally be provided. Such optional inputs may include but shall not be limited the following:

SET NOISE LEVEL (X,Y or Z AXIS) (this is a reference tolerance when analyzing jitter of hands in the game);

SET SAMPLING RATE (how often frames of the camera are being taken in and analyzed);

SET GEARING; and

SET MAPPING CHAIN.

As mentioned above, the ability to detect and track the movements of the controller 110 makes it possible to determine whether any predefined movements of the controller 110 are performed. That is, certain movement patterns or gestures of the controller 110 may be mapped to input commands for the game or other simulation.

Referring to FIG. 3B, there is illustrated a method 320 for use in providing input to a system in accordance with an embodiment of the present invention. The method 320 begins in step 322 in which position information for a controller for the system is determined. This step may be performed using the methods and techniques described above.

In step 324, the determined position information for the controller is compared with predetermined position information associated with commands. That is, any number of different movements, gestures or manipulations of the controller may be mapped to various commands. This allows different movements, gestures or manipulations of the controller to be mapped into game models. For example, moving the controller up may be mapped to one command, moving the controller down may be mapped to another command, and moving the controller in any other direction may be mapped to other commands.

Similarly, shaking the controller once may be mapped to one command, shaking the controller twice may be mapped to another command, and similarly, shaking the controller three, four, five, etc., times may be mapped to other commands. That is, various gestures may be established based on shaking the controller a certain number of times. Still other gestures may be established based on shaking the controller up and down vigorously a certain number of times. Other movements of the controller such as twisting, rolling, etc., may be mapped to still other commands.

Thus, various different trajectories of the game controller may be mapped onto gestures, which trigger commands in the game. Each command is mapped to a predetermined movement of the controller. Such predetermined movements of the controller will have associated predetermined position information. In this embodiment the determined position information for the controller is compared with the predetermined position information to see if a command should be triggered.

By way of example, such mapping of gestures to game commands may be implemented as follows. The outputs of the image analyzer may be used to determine position and orientation information for the controller. The image analyzer may output various different IDs that are indicative of position and orientation of the controller. For example, one ID may be output for a steady state determination, another ID may be output to indicate shaking of the controller, and various other IDs may be output to indicate other orientations. Thus, the use of such IDs may be used to output whether the controller is in steady state or is moving. If the controller is in steady state, an ID may indicate how long the controller has been in steady state.

The determined position and orientation information for the controller may then be compared with predetermined position information associated with input commands for the game. If the determined position information matches the predetermined position information for a command, then the command is provided to the entertainment system. Again, various gestures such as pushing the controller up or down, twisting in a circle, right or left, twisting while pulling it up or down, rolling right or left, etc., may all be mapped to various commands.

When a new command or gesture is recognized the image analyzer may trigger an interrupt. The triggering of such an interrupt may be used as part of the process of providing the command to the entertainment system. The system may optionally be configured so that zero acceleration points in the axes, stop points, and/or other events also trigger interrupts.

In comparing the determined position and orientation information with the predetermined position information associated with input commands to see if there is a match, it may often be the case that there is not an exact match. This is because with movement of the controller in free-space it may be difficult to precisely recreate a predefined movement. Therefore, the predetermined position information associated with input commands may be defined in terms of ranges, tolerances, and/or thresholds that are considered to be close enough to the predetermined position information such as to activate the command. That is, commands may be defined in terms of the thresholds or ranges. Thus, in determining whether or not any commands or gestures have been identified, the system may check to see if the determined position and orientation information falls within a range of a gesture. Thus, the defined commands may have thresholds that can be looked at in determining whether or not to invoke the command.

Furthermore, in comparing the determined position and orientation information with the predetermined position information associated with input commands to see if there is a match, histories of previous frames may be saved or mapped. For example, the frame buffer may be monitored or the system may otherwise keep running records of the history of the previous frames. The previous frames may be looked at to determine if any commands are met. The mapping of frame histories may allow the telemetry of the controller at a specific time to be determined to provide the position orientation in determining if a command is met.

Finally, in step 326 if the determined position information for the controller matches predetermined position information for a command, the command is provided to the system. Such command may be used to cause an event to occur or not occur in a video game or other simulation.

In other embodiments, the movements of a game controller may mapped to game commands, such as for example in video game. With such a method, which may be used in video games or other simulations, position information for a controller that is being manipulated by a user is received. The position information is analyzed to determine whether a predetermined movement of the controller associated with a command has been performed. This analysis may be performed as described above. If the predetermined movement of the controller associated with a command has been performed, then the command is executed by the game. The execution of the command may cause a visual effect or the like to occur on the video display that the game is being displayed on.

While the discussion herein is directed to the use of LEDs on the controller for a game or other entertainment system, it should be well understood that the teachings provided herein may be applied to detect and track the movements of controllers for other types of systems, devices, consumer electronics, etc. That is, the LEDs of the game controller described above can be used to perform remote control functions for consumer electronics devises or any device. LEDs may be used on the controllers for many other types of systems and devices in order to detect and track the controllers so that such movements may be mapped to commands for those systems and device. Examples of such other types of systems and devices may include, but are not limited to, televisions, stereos, telephones, computers, home or office networks, hand-held computing or communication device, etc.

Furthermore, the teachings described herein may be applied to universal remote controls that have the ability to control several or many different devices. That is, such universal remote controls may include LEDs as described herein such that movements of the universal remote control body may be used as input commands for several or many different devices or systems.

Moreover, a game controller may have a universal remote function. For example, such may comprise a body having a forward section to be oriented towards a screen when a progress of a game controlled in accordance with the game controller is displayed upon the screen. At least one input device may be assembled with the body with the input device manipulable by a user to register an input from the user. A signal encoder may be included. An infrared signal transmitter operable to transmit an infrared signal over the air using a signal generated by the signal encoder may be included. The signal encoder may be programmable to encode the signal with a selected one of a plurality of signaling codes for reception by an electronic device having an infrared receiver and a signal decoder operable with the selected one signaling code.

Moreover, battery operated toys (including toys molded into a form and style of a branded game) can be formed having LEDs and form a tracked user manipulated body in the sensed environment.

In some embodiments the image analyzer can recognize a user or process audio authenticated gestures, etc. A user may be identified by an analyzer in the system through a gesture and a gesture may be specific to a user. Gestures may be recorded by users and stored in models. The recordation process may optionally store audio generated during recordation of a gesture. The sensed environment may be sampled into a multi-channel analyzer and processed. The processor may reference gesture models to determine and authenticate user identity or objects based on voice or acoustic patterns and to a high degree of accuracy and performance.

According to embodiments of the present invention, the methods and techniques described herein may be implemented as part of a signal processing apparatus 400, as depicted in FIG. 4. The apparatus 400 may include a processor 401 and a memory 402 (e.g., RAM, DRAM, ROM, and the like). In addition, the signal processing apparatus 400 may have multiple processors 401 if parallel processing is to be implemented. The memory 402 may include data and code configured as described above.

Specifically, the memory 402 may include signal data 406. The memory 402 may also contain calibration data 408, e.g., data representing one or more inverse eigenmatrices C⁻¹ for one or more corresponding pre-calibrated listening zones obtained from calibration of a microphone array 422. By way of example the memory 402 may contain eignematrices for eighteen 20 degree sectors that encompass a microphone array 422.

The apparatus 400 may also include well-known support functions 410, such as input/output (I/O) elements 411, power supplies (P/S) 412, a clock (CLK) 413 and cache 414. The apparatus 400 may optionally include a mass storage device 415 such as a disk drive, CD-ROM drive, tape drive, or the like to store programs and/or data. The controller may also optionally include a display unit 416 and user interface unit 418 to facilitate interaction between the controller 400 and a user. The display unit 416 may be in the form of a cathode ray tube (CRT) or flat panel screen that displays text, numerals, graphical symbols or images. The user interface 418 may include a keyboard, mouse, joystick, light pen or other device. In addition, the user interface 418 may include a microphone, video camera or other signal transducing device to provide for direct capture of a signal to be analyzed. The processor 401, memory 402 and other components of the system 400 may exchange signals (e.g., code instructions and data) with each other via a system bus 420 as shown in FIG. 4.

The microphone array 422 may be coupled to the apparatus 400 through the I/O functions 411. The microphone array may include between about 2 and about 8 microphones, preferably about 4 microphones with neighboring microphones separated by a distance of less than about 4 centimeters, preferably between about 1 centimeter and about 2 centimeters. Preferably, the microphones in the array 422 are omni-directional microphones. An optional image capture unit 423 (e.g., a digital camera) may be coupled to the apparatus 400 through the I/O functions 411. One or more pointing actuators 425 that are mechanically coupled to the camera may exchange signals with the processor 401 via the I/O functions 411.

As used herein, the term I/O generally refers to any program, operation or device that transfers data to or from the system 400 and to or from a peripheral device. Every data transfer may be regarded as an output from one device and an input into another. Peripheral devices include input-only devices, such as keyboards and mouses, output-only devices, such as printers as well as devices such as a writable CD-ROM that can act as both an input and an output device. The term “peripheral device” includes external devices, such as a mouse, keyboard, printer, monitor, microphone, game controller, camera, external Zip drive or scanner as well as internal devices, such as a CD-ROM drive, CD-R drive or internal modem or other peripheral such as a flash memory reader/writer, hard drive.

In certain embodiments of the invention, the apparatus 400 may be a video game unit, which may include a joystick controller 430 coupled to the processor via the I/O functions 411 either through wires (e.g., a USB cable) or wirelessly. The joystick controller 430 may have analog joystick controls 431 and conventional buttons 433 that provide control signals commonly used during playing of video games. Such video games may be implemented as processor readable data and/or instructions which may be stored in the memory 402 or other processor readable medium such as one associated with the mass storage device 415.

The joystick controls 431 may generally be configured so that moving a control stick left or right signals movement along the X axis, and moving it forward (up) or back (down) signals movement along the Y axis. In joysticks that are configured for three-dimensional movement, twisting the stick left (counter-clockwise) or right (clockwise) may signal movement along the Z axis. These three axis—X Y and Z—are often referred to as roll, pitch, and yaw, respectively, particularly in relation to an aircraft.

In addition to conventional features, the joystick controller 430 may include one or more inertial sensors 432, which may provide position and/or orientation information to the processor 401 via an inertial signal. Orientation information may include angular information such as a tilt, roll or yaw of the joystick controller 430. By way of example, the inertial sensors 432 may include any number and/or combination of accelerometers, gyroscopes or tilt sensors. In a preferred embodiment, the inertial sensors 432 include tilt sensors adapted to sense orientation of the joystick controller with respect to tilt and roll axes, a first accelerometer adapted to sense acceleration along a yaw axis and a second accelerometer adapted to sense angular acceleration with respect to the yaw axis. An accelerometer may be implemented, e.g., as a MEMS device including a mass mounted by one or more springs with sensors for sensing displacement of the mass relative to one or more directions. Signals from the sensors that are dependent on the displacement of the mass may be used to determine an acceleration of the joystick controller 430. Such techniques may be implemented by program code instructions 404 which may be stored in the memory 402 and executed by the processor 401.

By way of example an accelerometer suitable as the inertial sensor 432 may be a simple mass elastically coupled at three or four points to a frame, e.g., by springs. Pitch and roll axes lie in a plane that intersects the frame, which is mounted to the joystick controller 430. As the frame (and the joystick controller 430) rotates about pitch and roll axes the mass will displace under the influence of gravity and the springs will elongate or compress in a way that depends on the angle of pitch and/or roll. The displacement and of the mass can be sensed and converted to a signal that is dependent on the amount of pitch and/or roll. Angular acceleration about the yaw axis or linear acceleration along the yaw axis may also produce characteristic patterns of compression and/or elongation of the springs or motion of the mass that can be sensed and converted to signals that are dependent on the amount of angular or linear acceleration. Such an accelerometer device can measure tilt, roll angular acceleration about the yaw axis and linear acceleration along the yaw axis by tracking movement of the mass or compression and expansion forces of the springs. There are a number of different ways to track the position of the mass and/or or the forces exerted on it, including resistive strain gauge material, photonic sensors, magnetic sensors, hall-effect devices, piezoelectric devices, capacitive sensors, and the like.

In addition, the joystick controller 430 may include one or more light sources 434, such as light emitting diodes (LEDs). The light sources 434 may be used to distinguish one controller from the other. For example one or more LEDs can accomplish this by flashing or holding an LED pattern code. By way of example, 5 LEDs can be provided on the joystick controller 430 in a linear or two-dimensional pattern. Although a linear array of LEDs is preferred, the LEDs may alternatively, be arranged in a rectangular pattern or an arcuate pattern to facilitate determination of an image plane of the LED array when analyzing an image of the LED pattern obtained by the image capture unit 423. Furthermore, the LED pattern codes may also be used to determine the positioning of the joystick controller 430 during game play. For instance, the LEDs can assist in identifying tilt, yaw and roll of the controllers. This detection pattern can assist in providing a better user/feel in games, such as aircraft flying games, etc. The image capture unit 423 may capture images containing the joystick controller 430 and light sources 434. Analysis of such images can determine the location and/or orientation of the joystick controller. Such analysis may be implemented by program code instructions 404 stored in the memory 402 and executed by the processor 401. To facilitate capture of images of the light sources 434 by the image capture unit 423, the light sources 434 may be placed on two or more different sides of the joystick controller 430, e.g., on the front and on the back (as shown in phantom). Such placement allows the image capture unit 423 to obtain images of the light sources 434 for different orientations of the joystick controller 430 depending on how the joystick controller 430 is held by a user.

In addition the light sources 434 may provide telemetry signals to the processor 401, e.g., in pulse code, amplitude modulation or frequency modulation format. Such telemetry signals may indicate which joystick buttons are being pressed and/or how hard such buttons are being pressed. Telemetry signals may be encoded into the optical signal, e.g., by pulse coding, pulse width modulation, frequency modulation or light intensity (amplitude) modulation. The processor 401 may decode the telemetry signal from the optical signal and execute a game command in response to the decoded telemetry signal. Telemetry signals may be decoded from analysis of images of the joystick controller 430 obtained by the image capture unit 423. Alternatively, the apparatus 401 may include a separate optical sensor dedicated to receiving telemetry signals from the lights sources 434. The use of LEDs in conjunction with determining an intensity amount in interfacing with a computer program is described, e.g., in commonly-owned U.S. patent application Ser. No. ______, to Richard L. Marks et al., entitled “USE OF COMPUTER IMAGE AND AUDIO PROCESSING IN DETERMINING AN INTENSITY AMOUNT WHEN INTERFACING WITH A COMPUTER PROGRAM” (Attorney Docket No. SONYP052), which is incorporated herein by reference in its entirety. In addition, analysis of images containing the light sources 434 may be used for both telemetry and determining the position and/or orientation of the joystick controller 430. Such techniques may be implemented by program code instructions 404 which may be stored in the memory 402 and executed by the processor 401.

The processor 401 may use the inertial signals from the inertial sensor 432 in conjunction with optical signals from light sources 434 detected by the image capture unit 423 and/or sound source location and characterization information from acoustic signals detected by the microphone array 422 to deduce information on the location and/or orientation of the joystick controller 430 and/or its user. For example, “acoustic radar” sound source location and characterization may be used in conjunction with the microphone array 422 to track a moving voice while motion of the joystick controller is independently tracked (through the inertial sensor 432 and or light sources 434). Any number of different combinations of different modes of providing control signals to the processor 401 may be used in conjunction with embodiments of the present invention. Such techniques may be implemented by program code instructions 404 which may be stored in the memory 402 and executed by the processor 401.

Signals from the inertial sensor 432 may provide part of a tracking information input and signals generated from the image capture unit 423 from tracking the one or more light sources 434 may provide another part of the tracking information input. By way of example, and without limitation, such “mixed mode” signals may be used in a football type video game in which a Quarterback pitches the ball to the right after a head fake head movement to the left. Specifically, a game player holding the controller 430 may turn his head to the left and make a sound while making a pitch movement swinging the controller out to the right like it was the football. The microphone array 420 in conjunction with “acoustic radar” program code can track the user's voice. The image capture unit 423 can track the motion of the user's head or track other commands that do not require sound or use of the controller. The sensor 432 may track the motion of the joystick controller (representing the football). The image capture unit 423 may also track the light sources 434 on the controller 430. The user may release of the “ball” upon reaching a certain amount and/or direction of acceleration of the joystick controller 430 or upon a key command triggered by pressing a button on the joystick controller 430.

In certain embodiments of the present invention, an inertial signal, e.g., from an accelerometer or gyroscope may be used to determine a location of the joystick controller 430. Specifically, an acceleration signal from an accelerometer may be integrated once with respect to time to determine a change in velocity and the velocity may be integrated with respect to time to determine a change in position. If values of the initial position and velocity at some time are known then the absolute position may be determined using these values and the changes in velocity and position. Although position determination using an inertial sensor may be made more quickly than using the image capture unit 423 and light sources 434 the inertial sensor 432 may be subject to a type of error known as “drift” in which errors that accumulate over time can lead to a discrepancy D between the position of the joystick 430 calculated from the inertial signal (shown in phantom) and the actual position of the joystick controller 430. Embodiments of the present invention allow a number of ways to deal with such errors.

For example, the drift may be cancelled out manually by re-setting the initial position of the joystick controller 430 to be equal to the current calculated position. A user may use one or more of the buttons on the joystick controller 430 to trigger a command to re-set the initial position. Alternatively, image-based drift may be implemented by re-setting the current position to a position determined from an image obtained from the image capture unit 423 as a reference. Such image-based drift compensation may be implemented manually, e.g., when the user triggers one or more of the buttons on the joystick controller 430. Alternatively, image-based drift compensation may be implemented automatically, e.g., at regular intervals of time or in response to game play. Such techniques may be implemented by program code instructions 404 which may be stored in the memory 402 and executed by the processor 401.

In certain embodiments it may be desirable to compensate for spurious data in the inertial sensor signal. For example the signal from the inertial sensor 432 may be oversampled and a sliding average may be computed from the oversampled signal to remove spurious data from the inertial sensor signal. In some situations it may be desirable to oversample the signal and reject a high and/or low value from some subset of data points and compute the sliding average from the remaining data points. Furthermore, other data sampling and manipulation techniques may be used to adjust the signal from the inertial sensor to remove or reduce the significance of spurious data. The choice of technique may depend on the nature of the signal, computations to be performed with the signal, the nature of game play or some combination of two or more of these. Such techniques may be implemented by program code instructions 404 which may be stored in the memory 402 and executed by the processor 401.

The processor 401 may perform digital signal processing on signal data 406 in response to the data 406 and program code instructions of a program 404 stored and retrieved by the memory 402 and executed by the processor module 401. Code portions of the program 404 may conform to any one of a number of different programming languages such as Assembly, C++, JAVA or a number of other languages. The processor module 401 forms a general-purpose computer that becomes a specific purpose computer when executing programs such as the program code 404. Although the program code 404 is described herein as being implemented in software and executed upon a general purpose computer, those skilled in the art will realize that the method of task management could alternatively be implemented using hardware such as an application specific integrated circuit (ASIC) or other hardware circuitry. As such, it should be understood that embodiments of the invention can be implemented, in whole or in part, in software, hardware or some combination of both.

In one embodiment, among others, the program code 404 may include a set of processor readable instructions that implement any one or more of the methods and techniques described herein or some combination of two or more of such methods and techniques. For example, the program code 404 may be configured to implement the image analyzer function described herein. Or alternatively, the image analyzer function described herein may be implemented in hardware.

In the illustrated embodiment the image analyzer function described above is illustrated as the image analyzer 450. The image analyzer 450 may receive its input from a camera, such as for example the image capture unit 423 or the camera 112 (FIG. 1A). Thus, the output of the video camera 112 or the image capture unit 423 may be coupled to the input of the image analyzer 450. The output of the image analyzer 450 may be provided to the system of the apparatus 400. This way, either commands themselves or information needed to see if a command or gesture has been recognized is provided to the apparatus 400. The image analyzer 450 may be coupled to the rest of the apparatus 400 in many different ways; as such, the illustrated connections are just one example. As another example, the image analyzer 450 may be coupled to the system bus 420, which will allow it to receive its input data from the image capture unit 423 and provide its output to the apparatus 400.

The image analyzer 450 may optionally be included in the apparatus 400 or the entertainment system or console 102, or the image analyzer 450 may be located separately from these devices and systems. And again, it should be well understood that the image analyzer 450 may be implemented, in whole or in part, in software, hardware or some combination of both. In the scenario where the image analyzer 450 is implemented in software, then the block 450 represents the image analyzer function implemented in software.

The program code 404 may generally include one or more instructions that direct the one or more processors to select a pre-calibrated listening zone at runtime and filter out sounds originating from sources outside the pre-calibrated listening zone. The pre-calibrated listening zones may include a listening zone that corresponds to a volume of focus or field of view of the image capture unit 423.

The program code may include one or more instructions which, when executed, cause the apparatus 400 to select a pre-calibrated listening sector that contains a source of sound. Such instructions may cause the apparatus to determine whether a source of sound lies within an initial sector or on a particular side of the initial sector. If the source of sound does not lie within the default sector, the instructions may, when executed, select a different sector on the particular side of the default sector. The different sector may be characterized by an attenuation of the input signals that is closest to an optimum value. These instructions may, when executed, calculate an attenuation of input signals from the microphone array 422 and the attenuation to an optimum value. The instructions may, when executed, cause the apparatus 400 to determine a value of an attenuation of the input signals for one or more sectors and select a sector for which the attenuation is closest to an optimum value.

The program code 404 may optionally include one or more instructions that direct the one or more processors to produce a discrete time domain input signal x_(m)(t) from the microphones M₀ . . . M_(M), determine a listening sector, and use the listening sector in a semi-blind source separation to select the finite impulse response filter coefficients to separate out different sound sources from input signal x_(m)(t). The program 404 may also include instructions to apply one or more fractional delays to selected input signals x_(m)(t) other than an input signal x₀(t) from a reference microphone M₀. Each fractional delay may be selected to optimize a signal to noise ratio of a discrete time domain output signal y(t) from the microphone array. The fractional delays may be selected to such that a signal from the reference microphone M₀ is first in time relative to signals from the other microphone(s) of the array. The program 404 may also include instructions to introduce a fractional time delay Δ into an output signal y(t) of the microphone array so that: y(t+Δ)=x(t+Δ)*b₀+x(t−1+Δ)*b₁+x(t−2+Δ)*b₂+ . . . +x(t−N+Δ)b_(N), where Δ is between zero and ±1.

The program code 404 may optionally include processor executable instructions including one or more instructions which, when executed cause the image capture unit 423 to monitor a field of view in front of the image capture unit 423, identify one or more of the light sources 434 within the field of view, detect a change in light emitted from the light source(s) 434; and in response to detecting the change, triggering an input command to the processor 401. The use of LEDs in conjunction with an image capture device to trigger actions in a game controller is described e.g., in commonly-owned, U.S. patent application Ser. No. 10/759,782 to Richard L. Marks, filed Jan. 16, 2004 and entitled: METHOD AND APPARATUS FOR LIGHT INPUT DEVICE, which is incorporated herein by reference in its entirety.

The program code 404 may optionally include processor executable instructions including one or more instructions which, when executed, use signals from the inertial sensor and signals generated from the image capture unit from tracking the one or more light sources as inputs to a game system, e.g., as described above. The program code 404 may optionally include processor executable instructions including one or more instructions which, when executed compensate for drift in the inertial sensor 432.

In addition, the program code 404 may optionally include processor executable instructions including one or more instructions which, when executed adjust the gearing and mapping of controller manipulations to game a environment. Such a feature allows a user to change the “gearing” of manipulations of the joystick controller 430 to game state. For example, a 45 degree rotation of the joystick controller 430 may be geared to a 45 degree rotation of a game object. However this 1:1 gearing ratio may be modified so that an X degree rotation (or tilt or yaw or “manipulation”) of the controller translates to a Y rotation (or tilt or yaw or “manipulation”) of the game object. Gearing may be 1:1 ratio, 1:2 ratio, 1:X ratio or X:Y ratio, where X and Y can take on arbitrary values. Additionally, mapping of input channel to game control may also be modified over time or instantly. Modifications may comprise changing gesture trajectory models, modifying the location, scale, threshold of gestures, etc. Such mapping may be programmed, random, tiered, staggered, etc., to provide a user with a dynamic range of manipulatives. Modification of the mapping, gearing or ratios can be adjusted by the program code 404 according to game play, game state, through a user modifier button (key pad, etc.) located on the joystick controller 430, or broadly in response to the input channel. The input channel may include, but may not be limited to elements of user audio, audio generated by controller, tracking audio generated by the controller, controller button state, video camera output, controller telemetry data, including accelerometer data, tilt, yaw, roll, position, acceleration and any other data from sensors capable of tracking a user or the user manipulation of an object.

In certain embodiments the program code 404 may change the mapping or gearing over time from one scheme or ratio to another scheme, respectively, in a predetermined time-dependent manner. Gearing and mapping changes can be applied to a game environment in various ways. In one example, a video game character may be controlled under one gearing scheme when the character is healthy and as the character's health deteriorates the system may gear the controller commands so the user is forced to exacerbate the movements of the controller to gesture commands to the character. A video game character who becomes disoriented may force a change of mapping of the input channel as users, for example, may be required to adjust input to regain control of the character under a new mapping. Mapping schemes that modify the translation of the input channel to game commands may also change during gameplay. This translation may occur in various ways in response to game state or in response to modifier commands issued under one or more elements of the input channel. Gearing and mapping may also be configured to influence the configuration and/or processing of one or more elements of the input channel.

In addition, a speaker 436 may be mounted to the joystick controller 430. In “acoustic radar” embodiments wherein the program code 404 locates and characterizes sounds detected with the microphone array 422, the speaker 436 may provide an audio signal that can be detected by the microphone array 422 and used by the program code 404 to track the position of the joystick controller 430. The speaker 436 may also be used to provide an additional “input channel” from the joystick controller 430 to the processor 401. Audio signals from the speaker 436 may be periodically pulsed to provide a beacon for the acoustic radar to track location. The audio signals (pulsed or otherwise) may be audible or ultrasonic. The acoustic radar may track the user manipulation of the joystick controller 430 and where such manipulation tracking may include information about the position and orientation (e.g., pitch, roll or yaw angle) of the joystick controller 430. The pulses may be triggered at an appropriate duty cycle as one skilled in the art is capable of applying. Pulses may be initiated based on a control signal arbitrated from the system. The apparatus 400 (through the program code 404) may coordinate the dispatch of control signals amongst two or more joystick controllers 430 coupled to the processor 401 to assure that multiple controllers can be tracked.

By way of example, embodiments of the present invention may be implemented on parallel processing systems. Such parallel processing systems typically include two or more processor elements that are configured to execute parts of a program in parallel using separate processors. By way of example, and without limitation, FIG. 5 illustrates a type of cell processor 500 according to an embodiment of the present invention. The cell processor 500 may be used as the processor 401 of FIG. 4. In the example depicted in FIG. 5, the cell processor 500 includes a main memory 502, power processor element (PPE) 504, and a number of synergistic processor elements (SPEs) 506. In the example depicted in FIG. 5, the cell processor 500 includes a single PPE 504 and eight SPE 506. In such a configuration, seven of the SPE 506 may be used for parallel processing and one may be reserved as a back-up in case one of the other seven fails. A cell processor may alternatively include multiple groups of PPEs (PPE groups) and multiple groups of SPEs (SPE groups). In such a case, hardware resources can be shared between units within a group. However, the SPEs and PPEs must appear to software as independent elements. As such, embodiments of the present invention are not limited to use with the configuration shown in FIG. 5.

The main memory 502 typically includes both general-purpose and nonvolatile storage, as well as special-purpose hardware registers or arrays used for functions such as system configuration, data-transfer synchronization, memory-mapped I/O, and I/O subsystems. In embodiments of the present invention, a signal processing program 503 may be resident in main memory 502. The signal processing program 503 may run on the PPE. The program 503 may be divided up into multiple signal processing tasks that can be executed on the SPEs and/or PPE.

By way of example, the PPE 504 may be a 64-bit PowerPC Processor Unit (PPU) with associated caches L1 and L2. The PPE 504 is a general-purpose processing unit, which can access system management resources (such as the memory-protection tables, for example). Hardware resources may be mapped explicitly to a real address space as seen by the PPE. Therefore, the PPE can address any of these resources directly by using an appropriate effective address value. A primary function of the PPE 504 is the management and allocation of tasks for the SPEs 506 in the cell processor 500.

Although only a single PPE is shown in FIG. 5, some cell processor implementations, such as cell broadband engine architecture (CBEA), the cell processor 500 may have multiple PPEs organized into PPE groups, of which there may be more than one. These PPE groups may share access to the main memory 502. Furthermore the cell processor 500 may include two or more groups SPEs. The SPE groups may also share access to the main memory 502. Such configurations are within the scope of the present invention.

Each SPE 506 is includes a synergistic processor unit (SPU) and its own local storage area LS. The local storage LS may include one or more separate areas of memory storage, each one associated with a specific SPU. Each SPU may be configured to only execute instructions (including data load and data store operations) from within its own associated local storage domain. In such a configuration, data transfers between the local storage LS and elsewhere in a system 500 may be performed by issuing direct memory access (DMA) commands from the memory flow controller (MFC) to transfer data to or from the local storage domain (of the individual SPE). The SPUs are less complex computational units than the PPE 504 in that they do not perform any system management functions. The SPU generally have a single instruction, multiple data (SIMD) capability and typically process data and initiate any required data transfers (subject to access properties set up by the PPE) in order to perform their allocated tasks. The purpose of the SPU is to enable applications that require a higher computational unit density and can effectively use the provided instruction set. A significant number of SPEs in a system managed by the PPE 504 allow for cost-effective processing over a wide range of applications.

Each SPE 506 may include a dedicated memory flow controller (MFC) that includes an associated memory management unit that can hold and process memory-protection and access-permission information. The MFC provides the primary method for data transfer, protection, and synchronization between main storage of the cell processor and the local storage of an SPE. An MFC command describes the transfer to be performed. Commands for transferring data are sometimes referred to as MFC direct memory access (DMA) commands (or MFC DMA commands).

Each MFC may support multiple DMA transfers at the same time and can maintain and process multiple MFC commands. Each MFC DMA data transfer command request may involve both a local storage address (LSA) and an effective address (EA). The local storage address may directly address only the local storage area of its associated SPE. The effective address may have a more general application, e.g., it may be able to reference main storage, including all the SPE local storage areas, if they are aliased into the real address space.

To facilitate communication between the SPEs 506 and/or between the SPEs 506 and the PPE 504, the SPEs 506 and PPE 504 may include signal notification registers that are tied to signaling events. The PPE 504 and SPEs 506 may be coupled by a star topology in which the PPE 504 acts as a router to transmit messages to the SPEs 506. Alternatively, each SPE 506 and the PPE 504 may have a one-way signal notification register referred to as a mailbox. The mailbox can be used by an SPE 506 to host operating system (OS) synchronization.

The cell processor 500 may include an input/output (I/O) function 508 through which the cell processor 500 may interface with peripheral devices, such as a microphone array 512 and optional image capture unit 513. In addition an Element Interconnect Bus 510 may connect the various components listed above. Each SPE and the PPE can access the bus 510 through a bus interface units BIU. The cell processor 500 may also includes two controllers typically found in a processor: a Memory Interface Controller MIC that controls the flow of data between the bus 510 and the main memory 502, and a Bus Interface Controller BIC, which controls the flow of data between the I/O 508 and the bus 510. Although the requirements for the MIC, BIC, BIUs and bus 510 may vary widely for different implementations, those of skill in the art will be familiar their functions and circuits for implementing them.

The cell processor 500 may also include an internal interrupt controller IIC. The IIC component manages the priority of the interrupts presented to the PPE. The IIC allows interrupts from the other components the cell processor 500 to be handled without using a main system interrupt controller. The IIC may be regarded as a second level controller. The main system interrupt controller may handle interrupts originating external to the cell processor.

In embodiments of the present invention, certain computations, such as fractional delays, may be performed in parallel using the PPE 504 and/or one or more of the SPE 506. Each fractional delay calculation may be run as one or more separate tasks that different SPE 506 may take as they become available.

Some embodiments provide a tracking device for use in obtaining information for controlling an execution of a game program by a processor for enabling an interactive game to be played by a user. The tracking device can include a body and at least one PD element. The body can further include a section to be oriented towards a screen when a progress of a game provided via execution of the game apparatus is displayed upon the screen. The at least one PD element can additionally be assembled with the body. A position of the PD element within an image can be recordable by an image capture device when the section is oriented at least partly towards the screen. In operation, positions of the PD element at different points in time are quantifiable to quantify movement of the body in space.

Further, the body can be mountable to a game controller. The game controller can include a game controller body and at least one input device assembled with the game controller body. The input device can be manipulable by a user such that an input from the user can be registered. In some instances the apparatus includes both the tracking device and the game controller.

In some embodiments, the PD element can include a retro-reflector. Additionally or alternatively, the PD element can have a color that has a high contrast relative to a color of a portion of the body adjacent to the PD element. Further, each of the at least one PD element can include a pattern that includes at least two different textures. For example, the textures can differ in at least one of brightness, color, roughness and/or other such relevant textures. In some embodiments, the PD element includes a light source, and in some implementations the light source can include at least one LED.

Further, some embodiments include two, three, four or more PD elements. These multiple PD elements can be oriented in one or more configurations. For example, in implementations with two PD elements, the PD elements can be oriented to define a line, and in some implementations with three PD elements, the elements can be oriented in a triangle. In other implementations having four PD elements, the elements can be arranged or positioned to define four lines. The four lines can define, for example, a rectangle or other relevant configuration.

The PD elements can include light sources and at least one of the light sources can be distinguishable from the other light sources by a characteristic relating to the light output by the at least one light source. The at least one light source can be distinguishable from the other light sources, for example, by at least one of a strobe frequency, an on-off duty cycle, a timing of an on interval within an on-off cycle, a spectral content of the output of the light source, and/or other such relevant distinctions and/or combinations of distinctions. In some embodiments, the body of the tracking device is mountable to the user's body.

The tracking devices according to some embodiments can further include a communications interface that can conduct digital communications with at least one of the processor, the game controller and/or both the processor and the game controller. The communications interface can be substantially any relevant interface, such as a universal asynchronous receiver transmitter (“UART”), universal serial bus (“USB”) controller, and/or other such relevant interfaces and/or combinations of interfaces. Typically, the interface is operable to perform at least one of receiving a control signal for controlling an operation of the tracking device, for transmitting a signal from the tracking device for communication with another device, and/or other such communication functionality.

Some embodiments further include a processor operable to execute a game program to display a progress of a game on a screen to enable the game to be interactively played by a user. The position of one or more PD elements can be recordable by an image capture device located, for example, in a vicinity of the screen, and the processor can be configured to detect the position of the PD element within the image using information outputted by the image capture device. Additionally or alternatively, the processor can be operable to detect user input information for controlling execution of the game program from the information outputted by the image capture device, to obtain a series of samples representative of acceleration of the body in space at different points in time from information outputted by the image capture device, and/or to determine a velocity of the body using the series of samples, for example by integrating acceleration values obtained from the series of samples over an interval of time.

The processor can, in some instances, can determine a displacement of the body in space by first integrating acceleration values obtained from the series of samples over an interval of time and then integrating a result of the first integrating. Additionally or alternatively, the processor can determine a position of the body in space by determining the displacement in relation to a previously determined position.

In some instances where the tracking device includes at least two of PD elements, the processor can obtain a series of samples representative of acceleration of the body in at least two degrees of freedom in space using the information outputted by the image capture device. When the tracking device includes at least three of the PD elements, the processor can obtain a series of samples representative of acceleration of the body in at least three degrees of freedom using the information outputted by the image capture device. The three degrees of freedom, for example, can include movement along three orthogonal axes x, y and z, and/or pitch, yaw and roll. In some embodiments, the processor can quantify the movement in six degrees of freedom, which can include, for example, three degrees of freedom and pitch, yaw and roll.

Further, some embodiments provide a controller. The controller can include a body, one or more buttons disposed on the body, and one or more detectable elements disposed on the body that are arranged in an array. Additionally in some implementations, the array is a linear array.

As mentioned above, computer entertainment systems typically include a handheld controller, game controller, or other controller. A user or player uses the controller to send commands or other instructions to the entertainment system to control a video game or other simulation being played. Televisions, stereos, other entertainment systems, and appliances also include handheld controllers.

Various embodiments of the methods, apparatus, schemes and systems described herein provide for the mapping of the three-dimensional movements of a handheld controller to the two-dimensional image plane of a display screen. This allows the three-dimensional movements of the entire controller body itself by the user to be used in controlling aspects of a system in which manipulations are performed on the two-dimensional image plane of the display screen.

For example, FIGS. 6A, 6B and 6C illustrate a system that operates in accordance with an embodiment of the present invention. In this embodiment, the three-dimensional movements of a handheld controller can be used for a mouse-like function in manipulating a pointer on the screen. For example, FIG. 6A illustrates a controller 602 held in the hands 604 of a player. An upward movement 606 of the controller 602 moves a cursor on the screen 608 of a display from a one position 610 up to another position 612. In FIG. 6B, a downward movement 620 of the controller 602 moves a cursor on the screen 608 of the display from a one position 622 down to another position 624. And in FIG. 6C, a sideways movement 630 of the controller 602 moves a cursor on the screen 608 of the display from a one position 632 sideways to another position 634. As will be discussed below, in other embodiments the three-dimensional movements of a handheld controller can be used for other functions, such as in a game for manipulating crosshairs or the like on the screen.

Referring to FIG. 7, there is illustrated a method 700 that operates in accordance with an embodiment of the present invention. The method 700 begins in step 702 in which the three-dimensional movements of a hand-held controller for a system are tracked. Such tracking may be performed in many different ways. For example, such tracking may be performed through inertial, video, acoustical, or infrared analysis in any of the manners described herein above or in any other manner.

In the example of video tracking, for example, a camera peripheral can be used with the computer entertainment system to detect motions of the hand-held controller body and transfer them into actions in a game. The camera can be used to detect many different types of motions of the controller, such as for example up and down movements, twisting movements, side to side movements, jerking movements, wand-like motions, plunging motions, etc. Again, however, the tracking may alternatively be performed through inertial, acoustical, or infrared analysis. For example, in embodiments that use infrared analysis, an infrared analyzer and a linear infrared array are used to determine a user's position and the orientation of a controller based on looking at the output of the sensors.

In step 704, the tracked three-dimensional movements of the handheld controller are then mapped onto the two-dimensional image plane of the screen of the display for the system. That is, the movements of the controller body itself in three-dimensions are cast onto the two-dimensional image plane that is on the screen. Thus, the three-dimensional movements of the controller are translated onto the X-Y coordinates of the two-dimensional image plane of the screen.

In step 706, one or more images are then displayed on the two-dimensional image plane of the screen based on the mapping of the tracked three-dimensional movements of the handheld controller. The images may comprise many different types of images. For example, as shown in FIGS. 6A, 6B and 6C, the images may comprise a pointer for use in selecting items displayed on the screen. In that example, the whole controller 602 itself becomes a mouse-like device and can be used like a mouse to control and select items on the screen like menus, links, etc.

Various different types of controller movements can be configured to cause various different movements of the images displayed on the screen. For example, the user may lift up on the controller or he or she can twist his or her wrist up, causing certain movements of the images. Or in another example, the user can push down on the controller location, and then point the nose down to have the cursor go further down. Or in another example, the user may move to the left with the position of the controller, but then the user twists the orientation to the left which makes the cursor go to the left. Or in another example, the user may move the controller to the right and also twists the orientation to the right which makes the cursor go to the right. Again, these are just examples and many other types of movements may be configured.

Referring to FIG. 8, there is illustrated another system that operates in accordance with an embodiment of the present invention. In this embodiment, the one or more images may comprise a set of crosshairs, such as for a shooter game. For example, in FIG. 8 the user or player may be walking through a three-dimensional space displayed on a screen 802 with the camera panning and moving through the game. A set of crosshairs 804 of the user's gun or the like are mapped to the X-Y coordinates of the two-dimensional image plane of the screen 802 over the three-dimensional space.

As the user moves the controller body 806 in three-dimensions, the movements cause the two-dimensional crosshairs 804 to move. As shown, a sideways and upward movement 810 of the controller body 806 causes a sideways and upward movement of the two-dimensional crosshairs 804 from one position 812 to another position 814. Thus, the games may comprise a three-dimensional game, but the crosshairs on the screen are mapped to the X and Y coordinates in the two-dimensional plane of the screen over the and three-dimensional space.

The examples described thus far illustrate that embodiments of the present invention allow the controller to be used as a mouse-like device for selecting menus, links, items, etc., but then the controller can change functions and be used for other functions, such as for example, controlling crosshairs in a shooting game. Thus, the detected movements, motions and/or manipulations of the entire controller body by the user may be used as additional commands to control various aspects of the game or other simulation being played.

In some embodiments, as an optional feature, the gearing of the manipulation to two-dimensional mapping may be adjusted or throttled so the user can move the cursor faster or slower based on the level of throttle that is chosen. This provides the user with flexibility in choosing the speed at which the cursor, crosshairs, etc., move in response to the motions and movements of the controller. Such gearing may be adjusted using any buttons or controls on the controller. By way of example, in some embodiments the gearing may be throttled using the variable buttons L2 and R2 (FIGS. 1B, 1C, 1D, and 1E) or any other buttons or controls.

As mentioned above, the three-dimensional movements of the hand-held controller may be tracked in many different ways, such as for example through inertial, video, acoustical, or infrared analysis as described above, or in any other manner. Referring to FIG. 9, there is illustrated a system 900 that operates in accordance with an embodiment of the present invention. As described above, “mixed mode” signals may be used whereby signals from one type of sensor may provide part of the tracking information input and signals generated from another type of sensor may provide another part of the tracking information input. As such, in one embodiment a feedback loop may comprise a mixer 902 that may be used to mix signals from any number of different types of sensors 904, such as inertial, video, acoustical, or infrared sensors. The output from the mixer 902 is then mapped to the two-dimensional image plane of the screen by a mapper 904 or the like. Images are then displayed 906 on the 2D image plane of the screen.

In this way the 3D movements, motions and manipulations of a controller may be sensed and tracked and then mapped through a mixer back to the 2D platform on the screen. By way of example, if video tracking is used, the 3D movements of the controller are cast onto the 2D image plane of the camera, and then the controller movements and transformations from the perspective of the 2D image plane of the camera are mapped onto the 2D platform of the screen.

In other embodiments of the present invention either the X or Y coordinate of the two-dimensional image plane of the screen may optionally stay locked. This way, when a player moves the controller in various directions the image that is displayed on the screen moves only in one direction because one of the X and Y coordinates may be locked. For example, FIG. 10 illustrates a system that operates in accordance with another embodiment of the present invention. In this embodiment, a user or player may be walking through a three-dimensional space displayed on a screen 1002 with the camera panning and moving through the game. A set of crosshairs 1004 of the user's gun or the like are mapped to the X-Y coordinates of the two-dimensional image plane of the screen 1002 over the three-dimensional space.

In this example the Y coordinate is locked. As such, a sideways and upward movement 1010 of the controller body 1006 causes the two-dimensional crosshairs 1004 to move sideways along only the X axis from one position 1012 to another position 1014. The crosshairs 1004 move only along the X axis because the Y axis has been locked.

In some embodiments the user can hold a button down, which locks in one of the axes. For example, the button may lock in the Y coordinate so wherever the user moves the controller, the image on the screen will move only along the X axis. That is, the Y coordinate will stay fixed. Thus, the user can twist the controller to the right and slide all the way to the right on the X axis, or twist the controller to the left and slide all the way to the left along the X axis. In some embodiments, when the user pushes the button again, this may be configured to unlock the previously locked axis, which again provides the user with full degrees of movement. In some embodiments, the user may push another button to lock in the X-coordinate, which allows the user to slide the crosshairs only up and down.

The hand-held controller may comprise any type of controller in accordance with various embodiments of the present invention. For example, while a video game console controller is illustrated, the controller may instead comprise any other type of controller, such as a traditional controller for a television, stereo, DVD player, etc. By way of example, FIG. 11A illustrates a traditional television controller 1102 that may be used in accordance with various embodiments of the present invention. Or, the controller may instead comprise any other type of object that may be tracked in the manner described herein. By way of example, FIG. 11B illustrates such an object 1104 that may be used in accordance with various embodiments of the present invention.

In some embodiments the position and yaw of the controller may be additive. This would allow controller movements to continue to move the cursor or cross-hairs in the same direction so that the movements “add” to the previous movements.

Another embodiment of the present invention provides a method of using the 3D motions and movements of the controller to change the user's viewpoint in a scene that is displayed.

Referring to FIG. 12, there is illustrated an example of such a method in accordance with an embodiment of the present invention. The method 1200, which may be used in any type of interactive system, begins in step 1202 where position information is received for a controller that is being manipulated by a user. In step 1204 the received position information is analyzed to determine whether a predetermined movement of the controller has been performed. And in step 1206, the user's viewpoint of a scene displayed on a display is changed in response to the predetermined movement of the controller being performed.

The method 1200 may be used in any type of interactive system or game, including but not limited to so-called first-person shooter games and third-person shooter games. Specifically, a first-person shooter game employs a camera scheme that is referred to herein as a first-person game or more generally a first-person camera setting. Similarly, a third-person shooter game employs a camera scheme that is referred to herein as a third-person game or more generally a third-person camera setting. In a first-person game the on-screen view simulates the in-game character's point of view with the camera movement normally being linked to the movement of the character. In a third-person game the player normally sees the game world from a viewpoint above and behind the main character. In many third-person games the camera movement is not linked to the movement of the main character.

The method 1200 may be used to change the user's viewpoint of a scene in both a first-person game and a third-person game. For example, in a third-person game where the camera movement may not be linked to the movement of the main character, the controller motions and movements may be used to control the camera movement to change the user's viewpoint. Specifically, many third-person camera schemes have the camera floating “in and about” and around the character. Even though a character's own eyes cannot see behind him or her, a third-person camera has the ability to do so. The camera may often be programmed to float in various patterns with those patterns being subject to conditions in the game.

The method 1200 may be used to augment the float so that the 3D manipulations and movements of the controller or changes in its orientation are used to influence the float scheme. For example, the float scheme employed by a camera viewing the scene may be influenced by changing the user's viewpoint in a manner not originally contemplated by the float scheme. In some embodiments such influence may be additive, gearing-related, and/or subtractive in order to influence the camera according to the framework it is installed. For example, in some embodiments the degree of the influencing may be controlled by a gearing setting. In some embodiments the influencing may be additive, which would allow controller movements to continue to change the user's viewpoint in the same direction so that the movements “add” to the previous movements. In some embodiments the influencing may be subtractive, which would have the opposite effect. In other embodiments the controller motions and movements may be used to change the user's viewpoint in other ways.

In a first-person game, for example, even though the camera movement may be linked to the movement of the character, the controller motions and movements may still be used to change the user's viewpoint. For example, in some embodiments the controller motions and movements may be used to simulate movement of the character's eyes even though the character's body remains still. In other embodiments the controller motions and movements may be used to change the user's viewpoint in other ways.

Therefore, in the below discussion it should be understood that the method 1200 may be applied to both first-person and third-person games, games offering both first-person and third-person camera viewpoints, as well as other scenarios and combinations of such genres.

By way of example, in some embodiments, the step of changing the user's viewpoint may comprise displaying a portion of the scene that was previously hidden by an obstruction, such as a corner, wall, rock, car, or any other obstruction or obstacle.

For example, FIG. 13A illustrates a display 1302 having an initial view with a chair 1304 against a wall 1306 and with the corner 1308 of the wall 1306 providing an obstruction. That is, the user or player cannot see what is around the corner 1308. FIG. 13B illustrates the display 1302 after the user's viewpoint has been changed to display a portion of the scene that was previously hidden by the obstruction. Namely, the camera position has now been changed so that the user or player can now see around the corner 1308, which reveals a person 1310, perhaps a villain, hiding behind the corner 1308. Thus, changing the user's viewpoint may essentially comprise camera control around a player character, either a third person character or a first person character.

For example, in some embodiments the 3D motions and movements of the controller may be used to control a camera in a game. This would leave the remaining stick controls to use in the game. The game may either comprise a third person game or a first person game. Using controller motions to control camera movements may be helpful in games having a lack of extra buttons. Namely, in games having a complex control scheme it is sometimes difficult to spare an extra stick or button for camera control. Embodiments of the present invention may allow camera control without sacrificing the game play. And with six degrees of freedom provided by the controller motions, this would allow ample control of the camera.

The predetermined movement of the controller may comprise any movement, motion or gesture, such as any such movements described herein above. For example, in some embodiments the predetermined movement of the controller may comprise a tilting of the controller.

By way of further example, and not as limitations herein: moving the controller up and down may be used to change the vertical viewing angle; tilting the controller up/down may be used to zoom in/out; and tilting the controller left/right may be used to rotate the camera around the player.

In some embodiments, rotating the controller left/right may be used to expand the field of view in that direction. This may be used as a kind of nudge for the viewport providing the player some limited control of the camera, which may allow the player to look a little bit left or right. Again, these features may be provided by using the controller motion detection functions described herein. The ability to zoom in/out may also be viewed as changing the Field of View, which is another way of describing the effect.

This method may be applied in many different scenarios and applications. For example, in some embodiments it may be used in a first person shooter game. What is already hard to do on console controllers is hide/duck and then look and fire from behind something. Namely, there is one button to hold to hide, one to fire, and then the player has to aim/track at the same time. With an embodiment of the above-described method the player may lean left or right to peek around corners, which could be done by tilting the controller left or right. For example, gently tilting the wrist can have the player peak out from cover, use the tilt to aim, and a button to fire.

In this way player camera movement may be mapped to this controller detection, thus reducing the need to use the right analog stick for looking around. This may be helpful in first person shooter situations where the player is tracking an non-player character who is hiding up high. Namely, the player may snap the controller up to quickly look up. Then the player may return the controller to its horizontal position to return the field of vision to directly in front of him or her.

In some embodiments subtle secondary movements may be mapped to controller detection as well. For example, the player can move the controller to lean around a corner, then quickly duck to avoid being hit, then quickly jump by lifting the controller quickly, etc. These types of movements and motions are normally be mapped to one or more buttons, but embodiments of the above-described method may be used to map them to a style of controller movement.

Thus, embodiments of the above-described method may be helpful in first person shooter games and the like. Such games have sometimes not transitioned well from the personal computer (PC) to the gaming console, as the controls are often awkward on a standard controller. But as described above, embodiments of the above-described method may be helpful for peeking around corners instead of using shoulder buttons. That is, the position and orientation of the controller may be read and used to look and shoot around corners.

Furthermore, some embodiments may use gun style or shaped controllers with the motion/orientation sensing technology described herein that would bring the experience more to life. Once calibrated to the screen, such a gun controller could act as an aiming device, detecting where it is pointing on screen. In some embodiments, ergonomically positioned joysticks and buttons, fluid and independent character movement, camera view control, and precise aiming may be executed simultaneously.

This method may be applied in many other different scenarios and applications. As another example, in some embodiments it may be used in any type of driving game, such as an automobile, boat, airplane, or any other driving game or simulation. Similar to as described above, the player camera movement may be mapped to controller detection so that the user's viewpoint of a scene is changed in response to predetermined movements of the controller being performed. Again, changing the user's viewpoint may comprise displaying a portion of the scene that was previously hidden by an obstruction. This may assist the player in driving the car, boat, etc.

Thus, the controller position and orientation may be used to control viewpoint and/or viewport. For example, the player can pan his or her view left by tilting the controller left, or pan right by tilting the controller right. This may be helpful in expanding awareness in first person shooter games, driving games, and similar games, simulations and scenarios.

Referring to FIG. 14, there is illustrated another method 1400 in accordance with an embodiment of the present invention. The method 1400, which may be used in any type of interactive system, begins in step 1402 in which position information is received for a controller that is being manipulated by a user. In step 1404 the received position information is analyzed to determine whether a predetermined movement of the controller has been performed. And in step 1406, at least a portion of a character in a scene displayed on a display is moved in response to the predetermined movement of the controller being performed. By way of example, the character that is moved may comprise any type of character, such as a first person character, third person character, etc.

The method 1400 may be used in many different applications, games, simulations, etc., to provide additional controls in the game, beyond the “hard buttons” and joysticks. By way of example, in sports such as football, the 3D motions and movements of the controller may be used to make the player character perform maneuvers and juke/dodge moves while running down field. In boxing the 3D motions and movements of the controller may be used for dodging, moving and defending the body from blows. In a boxing game the step of moving at least a portion of a character may comprise causing the character to perform a punch motion with its arm and/or fist.

In a first person shooter game, the 3D motions and movements of the controller may be used to make the player character dodge certain obstacles. For example, the look and movement may be mapped to the two joysticks, but for those real “panic-inducing” moments (like an enemy grenade landing nearby) the player will have the ability to dive/dodge for cover like in real life. The controller's motion often works great for this, especially when something needs to be done immediately and the player is panicking. Players may even do it instinctively. Some people move their bodies and their controllers when they want to move something on-screen. By jerking the controller in a direction, the player dives in that direction, for example. Also, in some embodiments rolling the character forward may be done by tilting the controller forward. With two analog sticks and a motion-sensitive controller, the movement of a shooter may feel more realistic, and diving and shooting may be more fun for the player. Alternatively, in some embodiments, the controller's motion may be for looking and the second joystick for dodging/diving.

In some embodiments, such as in a basketball game, a lifting motion of the controller may cause a lifting of the player character controlled by the user to make the character go up for a shot, block, or rebound. When controlling the ball, pressing a button may release it. Such control may be really fun and interactive for the user.

Embodiments of the above-described method can make input systems more user friendly and intuitive and may lead to enhanced and intuitive player movement. Many game designs quickly run out of input buttons, leaving developers struggling to find a ways to allow the user to perform actions in ever increasingly complicated game play scenarios. Embodiments of the above-described method can make powerful replacements for hard to remember button presses.

In some embodiments some examples of player character actions may include: crouch—move the controller downward; jump—move the controller up then down; climb—move to climbable surface then move the controller forward; strafe—move the controller side to side; swim or fly—move and rotate the controller in space in order to simulate movement in space that allows six degrees of freedom; swimming—tilt controller down to dive and up to rise. In some embodiments, swimming controls may be mapped to the 3D motions and movements of the controller. That is, controller motions may be used to control the manner in which a character swims. Thus, in a swimming game the step of moving at least a portion of a character may comprise causing the character to perform a swimming motion.

Embodiments of the above-described method may also be implemented in balancing games. For example, in a game with a certain number of cables running in a row, the user may use the 3D motions and movements of the controller to keep the player character's balance on the cables as the character races. Others can attack the player character, and the player character can jump over others or jump to other cables. Thus, in a balancing game the step of moving at least a portion of a character may comprise causing the character to perform a balancing motion. The 3D motions and movements of the controller may also be used to spin objects.

In some embodiments of the present invention, the step of moving at least a portion of a character in a scene displayed on a display may comprise causing or making the character manipulate an article, such as for example an article under the character's control or some other article. FIG. 15 illustrates an example of a character 1502 displayed in a scene displayed on a display 1504 manipulating an article 1506. The character 1502 may comprise any type of character, such as a first person character, third person character, etc. By way of example, in some embodiments, such an article 1506 may comprise a gun, weapon, frisbee, ball, steering wheel, handle bars, guitar, hockey stick, pool cue, skateboard, sword, golf club, paint brush, airplane, hang glider, automobile, vehicle, surf board, boat, or any other article, etc. That is, the character 1502 may be caused to manipulate any type of article 1506.

For example, in a shooter game, the player could make a single quick up-and-down motion of the controller to have his or her character reload a weapon. That is, navigation systems such as weapon reloading could be mapped to a controller movement. And the same with changing weapons; for example, in some embodiments the player may quickly raise the nose of the controller to reload, and quickly drop the nose to switch weapons.

In a combat driving game, a certain motion may indicate deploying a weapon. For example, an up-and-over the shoulder motion may be configured to tell the game to toss a grenade at an opponent. A circular motion or a side-front-side arc may be configured for shield activation.

In sports, such as for example in a football game, a certain motion of the controller may cause a character to hike the ball. In hockey the 3D motions and movements of the controller may be used for more precise puck handling. In billiards, controller movements may be used for aiming and better English on the cue. The 3D motions and movements of the controller may also be used for flipping paddles to deflect objects, trying to balance objects, and for games like sword play.

Video game beginners tend to (unintentionally and instinctively) move the controller a lot, almost as if it would help them in the game. In some embodiments of the present invention such movement will help. For example, in some embodiments of a driving game the 3D motions and movements of the controller may be used for steering or controlling the vehicle. For example, if the user is supposed to steer right and the game notices the controller moving or tilting right, the game may add in a bit of steering to help the player. In some embodiments the game may also show a message onscreen reminding the user to steer with the joystick instead of moving his or her hands.

Thus, in some embodiments of a driving game the 3D motions and movements of the controller may be used for controlling the steering wheel, or the controller may actually be used as a steering wheel. This may be used in many different embodiments, such as for example where the vehicle comprises a boat, a go-cart, or any other vehicle in a driving or racing game. Using the controller to steer leaves the analog sticks free for looking, or aiming a gun. Plus, the depth/pressure sensitive L2 and R2 triggers are good for accelerating/braking.

In some embodiments, tilting the controller on edge may cause the vehicle to tilt sideways onto two wheels. Tilting upwards and pushing forwards may activate a wheelie-popping turbo boost. In some embodiments, such motions of the controller may be optional and could be also be performed by a button press as well.

Another example of a game that may utilize an embodiment of the present invention is a frisbee game or simulation. For example, in a frisbee simulation the user may hold one of the handles on the controller and flick it in a direction for the throw. The rotated angle affects direction, force directs the speed and distance of the throw, and the user can affect the spin using the analog triggers (R2 or L2). In some embodiments these features can be combined with other features, such dog game for frisbee catching competitions, or as a “disc golf” (frisbee golf) game.

Another example of a game that may utilize an embodiment of the present invention is a putting game. In such a game the user may use the controller as a putter. The motions of the controller are detected and used to make a putter on the screen move. Some embodiments may include an entire game on putting challenges and mini-golf. In some embodiments the controller may be used to control a true golf swing.

In another example, the 3D motions and movements of the controller may be used for controlling a skateboard. For example, motion detection of the controller may be used for balancing, ollying off the character's board, and nose and tail grinds. In some embodiments, the skateboard trick may be triggered via a button combo, but the subtleties of the trick may be mapped to motion detection of the controller. This may give the player that extra sense that he or she is on a skateboard. Other examples include using the 3D motions and movements of the controller for controlling a surfboard, snowboard, and/or motorcycle, such as in a motocross game. With a motorcycle, the controller may be manipulated by the user like the handlebars on a motorcycle.

In other examples, the 3D motions and movements of the controller may be used for controlling frequency/amplitude of a signal, such as an audio signal, or the tilt left/right of the controller can be used to switch tracks, such as audio or video tracks. Or, the 3D motions and movements of the controller may be used in a painting game or simulation. For example, instead of using the mouse for painting, the motions of the controller may be used for painting a picture on a canvas or a wall.

In some embodiments the 3D motions and movements of the controller may be used for any game with flying. For example, the controller movements may be used for controlling pitch and yaw in airplanes. Or, the controller movements may be used for a space flight game. For example, one analog stick may be used for acceleration/deceleration, the other stick for the gun's facing, and the controller motions may be used to change the player's facing.

Another example of a flying game is hang gliding. By way of example, the tilt motions and movements of the controller may be used for manipulation of the subtleties of wind shifts when hang gliding. This may provide a realistic hang gliding game.

In some embodiments the 3D motions and movements of the controller may be used for a guitar playing game. For example, such a game may utilize a controller in the shape of a guitar, and the controller may include the motion/orientation sensing features described herein. As such, the game is able to sense how the player is holding the guitar/controller. Advanced moves, such as behind the head playing (ala Jimi Hendrix) may be sensed and detected and open a whole new way of playing such a game.

In some embodiments the 3D motions and movements of the controller may be used for games similar to LocoRoco™. In such embodiments the controller motion detection may be used as primary game play. The ability to detect motions of the controller and a rolling of the controller allows for implementation of a three-dimensional game where all dimensions of rolling are available.

Thus, the 3D motions and movements of the controller may be used for controlling a character and/or article in many different types of games and simulations. Such 3D motions and movements may comprise many different types of motions and movements. By way of example, and not as a limitation herein, a shaking action of the controller may be used to: activate a pump; punch something; bounce/dribble a ball (by shaking the controller up and down at regular intervals); pedal a bicycle; create a fan for starting/extinguishing a fire; clear smoke; reload a weapon (i.e. shotgun); wipe the windshield/helmet; shake the head of the player after taking a blow/remove blurry vision; mix explosive paste to make it sticky; activate a light stick (chemical light); revive someone else (+health); repair an object (radio/screen goes from crackling/noise to clear); check presence of an object or the level of a liquid in an opaque; and/or contain sound.

Similarly, a rotation/tilt/sliding action of the controller may be used for: strafing (sliding left or right); opening a safe (find the combination); picking a lock on a door; opening a door handle; turning a valve; activating a crank; turning the focus ring of a lens; changing weapons; starting an engine (key); controlling a remote weapon independently from the player movement (tank turret etc.); a power gauge (to lob a grenade, baseball, golf, etc.).

And similarly, a rocking/pitch action of the controller may be used for: zooming a rifle scope; jumping/standing/ducking/prone; raising a canon; flipping a switch; arming a bow/crossbow/graple/catapult/slingshot; reeling a fish pole; putting (golf); braking/accelerating; raising/lowering a crate while driving a forklift; and/or lifting objects, like pumping iron.

And similarly, any combination of such actions of the controller may be used for: aiming; sword play; swimming/flying/driving/paddling; rhythm game; controlling the levels of a planar object; sliding; user interactions with items (e.g. levers, switches, etc.); movements on transports (e.g. snowboard in 3rd person overhead); and/or implementation of “party” games that are geared towards demonstrating the features and methods described herein.

In some embodiments of the present invention the ability to detect and use the 3D motions and movements of the controller may be toggled on and off so that the user has the choice of whether or not to use the feature. In some embodiments the motion control feature may be used as an extension of current controller schemes, but not as primary control. This gives the player the precision of using the pad and face buttons but allows the motion control to make the whole gaming experience feel more organic and involved. And in some embodiments the motion control feature may be used as primary control.

Thus, the 3D motions and movements of the controller may be used to make games easier to learn and play, which may make such games more accessible to larger groups. The added degree of realism in physically moving the controller around may enhance game play.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/551,197, filed Oct. 19, 2006, entitled “CONTROLLER CONFIGURED TO TRACK USER'S LEVEL OF ANXIETY AND OTHER MENTAL AND PHYSICAL ATTRIBUTES”, and identified as Attorney Docket No. 86400 [SCEA06063US00], is hereby fully incorporated by reference herein in its entirety.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/536,559, filed Sep. 28, 2006, entitled “MAPPING MOVEMENTS OF A HAND-HELD CONTROLLER TO THE TWO-DIMENSIONAL IMAGE PLANE OF A DISPLAY SCREEN”, (Attorney Docket No. 86335 [SCEA06058US00]), is hereby fully incorporated by reference herein in its entirety.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,699, filed May 10, 2006, entitled “ATTACHABLE STRUCTURE FOR USE WITH HAND-HELD CONTROLLER HAVING TRACKING ABILITY”, (Attorney Docket No. 87906 [SCEA06028US00]), is hereby fully incorporated by reference herein in its entirety.

The entire disclosure of U.S. Provisional Patent Application No. 60/718,145, entitled “AUDIO, VIDEO, SIMULATION, AND USER INTERFACE PARADIGMS”, filed Sep. 15, 2005, is hereby fully incorporated by reference herein in its entirety.

The following applications are all hereby fully incorporated herein by reference in their entireties: U.S. patent application Ser. No. 10/207,677, entitled, “MAN-MACHINE INTERFACE USING A DEFORMABLE DEVICE”, filed on Jul. 27, 2002; U.S. patent application Ser. No. 10/650,409, entitled, “AUDIO INPUT SYSTEM”, filed on Aug. 27, 2003; U.S. patent application Ser. No. 10/663,236, entitled “METHOD AND APPARATUS FOR ADJUSTING A VIEW OF A SCENE BEING DISPLAYED ACCORDING TO TRACKED HEAD MOTION”, filed on Sep. 15, 2003; U.S. patent application Ser. No. 10/759,782, entitled “METHOD AND APPARATUS FOR LIGHT INPUT DEVICE”, filed on Jan. 16, 2004; U.S. patent application Ser. No. 10/820,469, entitled “METHOD AND APPARATUS TO DETECT AND REMOVE AUDIO DISTURBANCES”, filed on Apr. 7, 2004; and U.S. patent application Ser. No. 11/301,673, entitled “METHOD FOR USING RELATIVE HEAD AND HAND POSITIONS TO ENABLE A POINTING INTERFACE VIA CAMERA TRACKING”, filed on Dec. 12, 2005, all of which are hereby incorporated by reference.

The following applications are all hereby fully incorporated herein by reference in their entireties: U.S. patent application Ser. No. 11/381,729, to Xiadong Mao, entitled “ULTRA SMALL MICROPHONE ARRAY”, (Attorney Docket SCEA05062US00), filed on May 4, 2006, application Ser. No. 11/381,728, to Xiadong Mao, entitled “ECHO AND NOISE CANCELLATION”, (Attorney Docket SCEA05064US00), filed on May 4, 2006, U.S. patent application Ser. No. 11/381,725, to Xiadong Mao, entitled “METHODS AND APPARATUS FOR TARGETED SOUND DETECTION”, (Attorney Docket SCEA05072US00), filed on May 4, 2006, U.S. patent application Ser. No. 11/381,727, to Xiadong Mao, entitled “NOISE REMOVAL FOR ELECTRONIC DEVICE WITH FAR FIELD MICROPHONE ON CONSOLE”, (Attorney Docket SCEA05073US00), filed on May 4, 2006, U.S. patent application Ser. No. 11/381,724, to Xiadong Mao, entitled “METHODS AND APPARATUS FOR TARGETED SOUND DETECTION AND CHARACTERIZATION”, (Attorney Docket SCEA05079US00), filed on May 4, 2006, U.S. patent application Ser. No. 11/381,721, to Xiadong Mao, entitled “SELECTIVE SOUND SOURCE LISTENING IN CONJUNCTION WITH COMPUTER INTERACTIVE PROCESSING”, (Attorney Docket SCEA04005JUMBOUS), filed on May 4, 2006; all of which are hereby incorporated by reference.

The following applications are all hereby fully incorporated herein by reference in their entireties: co-pending application Ser. No. 11/418,988, to Xiadong Mao, entitled “METHODS AND APPARATUSES FOR ADJUSTING A LISTENING AREA FOR CAPTURING SOUNDS”, (Attorney Docket SCEA-00300) filed on May 4, 2006; co-pending application Ser. No. 11/418,989, to Xiadong Mao, entitled “METHODS AND APPARATUSES FOR CAPTURING AN AUDIO SIGNAL BASED ON VISUAL IMAGE”, (Attorney Docket SCEA-00400), filed on May 4, 2006; co-pending application Ser. No. 11/429,047, to Xiadong Mao, entitled “METHODS AND APPARATUSES FOR CAPTURING AN AUDIO SIGNAL BASED ON A LOCATION OF THE SIGNAL”, (Attorney Docket SCEA-00500), filed on May 4, 2006; co-pending application Ser. No. 11/429,133, to Richard Marks et al., entitled “SELECTIVE SOUND SOURCE LISTENING IN CONJUNCTION WITH COMPUTER INTERACTIVE PROCESSING”, (Attorney Docket SCEA04005US01-SONYP045), filed on May 4, 2006; and co-pending application Ser. No. 11/429,414, to Richard Marks et al., entitled “COMPUTER IMAGE AND AUDIO PROCESSING OF INTENSITY AND INPUT DEVICES FOR INTERFACING WITH A COMPUTER PROGRAM”, (Attorney Docket SONYP052), filed on May 4, 2006, all of the entire disclosures of which are incorporated herein by reference.

The following applications are all hereby fully incorporated herein by reference in their entireties: U.S. patent application Ser. No. 11/382,031, entitled “MULTI-INPUT GAME CONTROL MIXER”, (Attorney Docket SCEA06MXR1), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,032, entitled “SYSTEM FOR TRACKING USER MANIPULATIONS WITHIN AN ENVIRONMENT”, (Attorney Docket SCEA06MXR2), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,033, entitled “SYSTEM, METHOD, AND APPARATUS FOR THREE-DIMENSIONAL INPUT CONTROL”, (Attorney Docket SCEA061NRT1), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,035, entitled “INERTIALLY TRACKABLE HAND-HELD CONTROLLER”, (Attorney Docket SCEA06INRT2), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,036, entitled “METHOD AND SYSTEM FOR APPLYING GEARING EFFECTS TO VISUAL TRACKING”, (Attorney Docket SONYP058A), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,041, entitled “METHOD AND SYSTEM FOR APPLYING GEARING EFFECTS TO INERTIAL TRACKING”, (Attorney Docket SONYP058B), filed on May 7, 2006; U.S. patent application Ser. No. 11/382,038, entitled “METHOD AND SYSTEM FOR APPLYING GEARING EFFECTS TO ACOUSTICAL TRACKING”, (Attorney Docket SONYP058C), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,040, entitled “METHOD AND SYSTEM FOR APPLYING GEARING EFFECTS TO MULTI-CHANNEL MIXED INPUT”, (Attorney Docket SONYP058D), filed on May 7, 2006; U.S. patent application Ser. No. 11/382,034, entitled “SCHEME FOR DETECTING AND TRACKING USER MANIPULATION OF A GAME CONTROLLER BODY”, (Attorney Docket 86321 SCEA05082US00), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,037, entitled “SCHEME FOR TRANSLATING MOVEMENTS OF A HAND-HELD CONTROLLER INTO INPUTS FOR A SYSTEM”, (Attorney Docket 86324), filed on May 6, 2006; U.S. patent application Ser. No. 11/382,043, entitled “DETECTABLE AND TRACKABLE HAND-HELD CONTROLLER”, (Attorney Docket 86325), filed on May 7, 2006; U.S. patent application Ser. No. 11/382,039, entitled “METHOD FOR MAPPING MOVEMENTS OF A HAND-HELD CONTROLLER TO GAME COMMANDS”, (Attorney Docket 86326), filed on May 7, 2006; U.S. Design patent application No. 29/259,349, entitled “CONTROLLER WITH INFRARED PORT”, (Attorney Docket SCEA06007US00), filed on May 6, 2006; U.S. Design patent application No. 29/259,350, entitled “CONTROLLER WITH TRACKING SENSORS”, (Attorney Docket SCEA06008US00), filed on May 6, 2006; U.S. Patent Application No. 60/798,031, entitled “DYNAMIC TARGET INTERFACE”, (Attorney Docket SCEA06009US00), filed on May 6, 2006; and U.S. Design patent application No. 29/259,348, entitled “TRACKED CONTROLLER DEVICE”, (Attorney Docket SCEA06010US00), filed on May 6, 2006; all of which are hereby incorporated herein by reference in their entireties.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/430,594, to Gary Zalewski and Riley R. Russell, entitled “Profile Detection”, (Attorney Docket SCEA05059US00), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. ______, to Gary Zalewski and Riley R. Russell, entitled “Using Audio/Visual Environment To Select Ads On Game Platform”, (Attorney Docket SCEAJP 3.0-003 CIP V), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/400,997, filed on Apr. 10, 2006, to Larsen and Chen, entitled “System And Method For Obtaining User Information From Voices”, (Attorney Docket SCEA05040US00), is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,259, to Gary Zalewski et al., entitled “Method and apparatus for use in determining lack of user activity in relation to a system”, (Attorney Docket 86327), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,258, to Gary Zalewski et al., entitled “Method and apparatus for use in determining an activity level of a user in relation to a system”, (Attorney Docket 86328), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,251, to Gary Zalewski et al., entitled “Hand-held controller having detectable elements for tracking purposes”, (Attorney Docket 86329), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,252, entitled “TRACKING DEVICE FOR USE IN OBTAINING INFORMATION FOR CONTROLLING GAME PROGRAM EXECUTION”, (Attorney Docket SCEA061NRT3), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,256 entitled “TRACKING DEVICE WITH SOUND EMITTER FOR USE IN OBTAINING INFORMATION FOR CONTROLLING GAME PROGRAM EXECUTION”, (Attorney Docket SCEA06ACRA2), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. patent application Ser. No. 11/382,250 entitled “OBTAINING INPUT FOR CONTROLLING EXECUTION OF A GAME PROGRAM”, (Attorney Docket SCEA06COMB), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,744, entitled “VIDEO GAME CONTROLLER FRONT FACE”, (Attorney Docket SCEACTR-D3), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent Application No. 29/246,743, entitled “VIDEO GAME CONTROLLER”, (Attorney Docket SCEACTRL-D2), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,767, entitled “VIDEO GAME CONTROLLER”, (Attorney Docket SONYP059A), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,768, entitled “VIDEO GAME CONTROLLER”, (Attorney Docket SONYP059B), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,763, entitled “ERGONOMIC GAME CONTROLLER DEVICE WITH LEDS AND OPTICAL PORTS”, (Attorney Docket PA3760US), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,759, entitled “GAME CONTROLLER DEVICE WITH LEDS AND OPTICAL PORTS”, (Attorney Docket PA3761US), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,765, entitled “DESIGN FOR OPTICAL GAME CONTROLLER INTERFACE”, (Attorney Docket PA3762US), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,766, entitled “DUAL GRIP GAME CONTROL DEVICE WITH LEDS AND OPTICAL PORTS”, (Attorney Docket PA3763US), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,764, entitled “GAME INTERFACE DEVICE WITH LEDS AND OPTICAL PORTS”, (Attorney Docket PA3764US), filed on May 8, 2006, is incorporated herein by reference.

The entire disclosure of co-pending U.S. Design patent application No. 29/246,762, entitled “ERGONOMIC GAME INTERFACE DEVICE WITH LEDS AND OPTICAL PORTS”, (Attorney Docket PA3765US), filed on May 8, 2006, is incorporated herein by reference.

While the invention herein disclosed has been described by means of specific embodiments and applications thereof, numerous modifications and variations could be made thereto by those skilled in the art without departing from the scope of the invention set forth in the claims. 

1. A method for use in an interactive system, comprising: receiving position information for a controller that is being manipulated by a user; analyzing the received position information to determine whether a predetermined movement of the controller has been performed; and changing the user's viewpoint of a scene displayed on a display in response to the predetermined movement of the controller being performed.
 2. A method in accordance with claim 1, wherein the step of changing the user's viewpoint comprises displaying a portion of the scene that was previously hidden by an obstruction.
 3. A method in accordance with claim 1, wherein the obstruction comprises a corner.
 4. A method in accordance with claim 1, wherein the obstruction comprises a wall.
 5. A method in accordance with claim 1, wherein the predetermined movement of the controller comprises a tilting of the controller.
 6. A method in accordance with claim 1, wherein the step of changing the user's viewpoint comprises changing the user's viewpoint in a first-person camera setting.
 7. A method in accordance with claim 1, wherein the step of changing the user's viewpoint comprises changing the user's viewpoint in a third-person camera setting.
 8. A method in accordance with claim 1, wherein the step of changing the user's viewpoint comprises influencing a float scheme employed by a camera viewing the scene.
 9. A method in accordance with claim 8, wherein a degree of the influencing is controlled by a gearing setting.
 10. A method in accordance with claim 8, wherein the influencing is additive.
 11. A method in accordance with claim 8, wherein the influencing is subtractive.
 12. A method in accordance with claim 1, wherein the step of changing the user's viewpoint comprises zooming in or out of the scene displayed on the display.
 13. A method for use in an interactive system, comprising: receiving position information for a controller that is being manipulated by a user; analyzing the received position information to determine whether a predetermined movement of the controller has been performed; and moving at least a portion of a character in a scene displayed on a display in response to the predetermined movement of the controller being performed.
 14. A method in accordance with claim 13, wherein the step of moving at least a portion of a character comprises causing the character to manipulate an article.
 15. A method in accordance with claim 14, wherein the article comprises an article under the character's control.
 16. A method in accordance with claim 14, wherein the article comprises a gun.
 17. A method in accordance with claim 14, wherein the article comprises a weapon.
 18. A method in accordance with claim 14, wherein the article comprises a frisbee.
 19. A method in accordance with claim 14, wherein the article comprises a ball.
 20. A method in accordance with claim 14, wherein the article comprises a steering wheel.
 21. A method in accordance with claim 14, wherein the article comprises handle bars.
 22. A method in accordance with claim 14, wherein the article comprises a gun.
 23. A method in accordance with claim 14, wherein the article comprises a guitar.
 24. A method in accordance with claim 14, wherein the article comprises a hockey stick.
 25. A method in accordance with claim 14, wherein the article comprises a pool cue.
 26. A method in accordance with claim 14, wherein the article comprises a skateboard.
 27. A method in accordance with claim 14, wherein the article comprises a golf club.
 28. A method in accordance with claim 14, wherein the article comprises a paint brush.
 29. A method in accordance with claim 14, wherein the article comprises an airplane.
 30. A method in accordance with claim 14, wherein the article comprises a hang glider.
 31. A method in accordance with claim 14, wherein the article comprises a surf board.
 32. A method in accordance with claim 14, wherein the article comprises an automobile.
 33. A method in accordance with claim 14, wherein the article comprises a boat.
 34. A method in accordance with claim 14, wherein the article comprises a vehicle.
 35. A method in accordance with claim 14, wherein the article comprises a paddle.
 36. A method in accordance with claim 13, wherein the step of moving at least a portion of a character comprises causing the character to perform a punch motion with its arm.
 37. A method in accordance with claim 13, wherein the step of moving at least a portion of a character comprises causing the character to perform a balancing motion.
 38. A method in accordance with claim 13, wherein the step of moving at least a portion of a character comprises causing the character to perform a swimming motion. 